{% extends "../single_page.html" %}

{% block title %}
<title>样本库信息管理 核酸使用记录信息</title>
{% endblock %}

{% block header_title %}
<h1>核酸使用记录信息</h1>
{% endblock %}

{% block header_ol %}
    <li class="breadcrumb-item"><a href="/Home/">Home</a></li>
    <li class="breadcrumb-item">BIS</li>
    <li class="breadcrumb-item active">DNAUsageRecordInfo</li>
{% endblock %}

{% block card-body %}
<table id="table" class="table table-bordered table-hover dt-responsive">
<thead>
<tr>
    <th>索引</th>
    <th>核酸提取编号</th>
    <th>华大编号</th>
    <th>生物样本编号</th>
    <th>使用日期</th>
    <th>使用量(ng)</th>
    <th>用途</th>
    <th>建库编号</th>
    <th>备注</th>
    <th>上次修改时间</th>
    <th>创建时间</th>
    <th>操作</th>
</tr>
</thead>
</table>
{% endblock %}

{% block ModalFormHeader %}
    <p id="ModalFormHeader" class="text-warning front-weight-bold"></p>
{% endblock %}

{% block ModalForm %}
    <div class="form-group">
        <span><a class="text-danger front-weight-bold">* </a>
            <label for="dna_id"> 核酸提取编号</label></span>
        <input type="text" class="form-control" id="dna_id" name="dna_id"
               placeholder="请输入核酸提取编号，必填" required="true">
    </div>
    <div class="form-group">
        <label for="usage_date"> 使用日期</label>
        <input type="date" class="form-control" id="usage_date" name="usage_date"
               placeholder="请输入使用日期" required="true">
    </div>
    <div class="form-group">
        <label for="mass"> 使用量(ng)</label>
        <input type="number" step="0.01" class="form-control" id="mass" name="mass"
               placeholder="请输入使用量(ng)，默认：0" value="0">
    </div>
    <div class="form-group">
        <label for="usage"> 用途</label>
        <select class="form-control" id="usage" name="usage">
            <option value="建库失败" selected="selected">建库失败</option>
            <option value="科研项目">科研项目</option>
            <option value="其他">其他</option>
        </select>
    </div>
    <div class="form-group">
        <label for="memo"> 备注</label>
        <input type="text" class="form-control" id="memo" name="memo"
               placeholder="请输入备注，默认：无" value="无">
    </div>
{% endblock %}

{% block page-script %}
<script>
    $(document).ready(function () {
        $("#sidebar_BIS>a").addClass("active");
        $("#sidebar_BIS").addClass("menu-open");
        $("#sidebar_BIS>ul>li:eq(3)>a").addClass("active");
        $(".sidebar").removeAttr("hidden");

        let model0 = "DNAUsageRecordInfo";
        let url0 = '/api/BIS/' + model0 + '/';
        let url1 = '/api/BIS/ExtractInfo/';
        let id0 = 0;
        let dataModelForm; //更新弹窗默认值，重置按钮需要

      let data0 = $.ajax({
          url: url0, dataType: 'json', contentType: "application/json",
          type: "get", async: false, data: {fields: "id"}
      }).responseJSON;
      $("#card-title1").text("核酸使用记录信息 总条目数：" + data0.length);

      function MyModelInit(title_name, data) {
          dataModelForm = data;
          if (title_name === '更新') {
              $('#dna_id').val(data['dna_id']);
              $('#usage_date').val(data['usage_date']);
              $('#mass').val(data['mass']);
              $('#usage').val(data['usage']);
              $('#singleLB_id').val(data['singleLB_id']);
              $('#memo').val(data['memo']);
              $('#type').val('edit');
              $('#modal_title').text('更新');
          } else {
              $('#dna_id').val("");
              $('#type').val('new');
              $('#modal_title').text('新增');
          }
      }

      let table = $('#table').DataTable({
          "paging": true,
          "ordering": true,
          "info": true,
          "autoWidth": false,
          "responsive": true,
          "language": {
                    "lengthMenu": "选择每页 _MENU_ 展示 ",
                    "zeroRecords": "未找到匹配结果--抱歉",
                    "info": "当前显示第 _PAGE_ 页结果，共 _PAGES_ 页",
                    "infoEmpty": "没有数据",
                    "search": "搜索",
                    "infoFiltered": "(获取 _MAX_ 项结果)",
                    "paginate": {
                        "first": "首页",
                        "previous": "上一页",
                        "next": "下一页",
                        "last": "末页"
                    }
                },
          "scrollY": "500px",
          "scrollCollapse": true,
          "scrollX": true,
          "pagingType": "full_numbers",
          //"fixedColumns": true,
          "rowReorder": true,
          "colReorder": true,
          "searching": true,
          "select": true,
          "fixedHeader": true,
          "lengthChange": true,
          "lengthMenu": [[10, 25, 50, 100, -1], [10, 25, 50, 100, "全部"]],
          "serverSide": true,
          "processing": true,
          "deferRender": true,
          "dom": 'rilB<"clear">ftp',
          "buttons": [
              /*
              {
                extend: 'pageLength',
                text: '显示行数'
              },
              */
              {
                  extend: 'colvisGroup',
                  text: '显示前5列',
                  className: 'btn btn-info fas fa-low-vision my-1',
                  show: [0, 1, 2, 3, 4, 5, 11],
                  hide: [6, 7, 8, 9, 10]
              },
              {
                  extend: 'colvisGroup',
                  text: '显示全部列',
                  className: 'btn btn-info far fa-eye my-1',
                  show: ':hidden',
              },
              {
                  extend: 'selectAll',
                  className: 'btn btn-primary fab fa-autoprefixer my-1',
                  text: '全选'
              },
              {
                  extend: 'selectRows',
                  className: 'btn btn-primary far fa-check-circle my-1',
                  text: '选择多行'
              },
              {
                  extend: 'selectNone',
                  className: 'btn btn-primary fas fa-ban my-1',
                  text: '取消当前选择'
              },
              {
                  extend: 'copy',
                  text: '所选复制到剪切板',
                  className: 'btn btn-success fas fa-copy my-1',
                  exportOptions: {
                      columns: range(11)
                  }
              },
              {
                  extend: 'csv',
                  text: '所选输出到csv',
                  className: 'btn btn-success fas fa-file-csv my-1',
                  exportOptions: {
                      columns: range(11)
                  }
              },
              {
                  extend: 'csv',
                  text: '全部输出到csv',
                  className: 'btn btn-success fas fa-file-excel my-1',
                  exportOptions: {
                      columns: range(11),
                      selected: null
                  }
              },
              {
                  text: '添加单行',
                  className: 'btn btn-warning fas fa-edit my-1',
                  action: function ( e, dt, node, config ) {

                  },
                  attr: {
                      id: 'new'
                  }
              },
            {% if perms.BIS.bulk_update_DNAUsageRecordInfo %}
              {
                  text: '批量添加模板下载',
                  className: 'btn btn-success fas fa-download my-1',
                  action: function ( e, dt, node, config ) {

                  },
                  attr: {
                      id: 'downloadExcel'
                  }
              },
              {
                  text: '批量添加',
                  className: 'btn btn-warning fas fa-upload my-1',
                  action: function ( e, dt, node, config ) {

                  },
                  attr: {
                      id: 'upload'
                  }
              },
            {% endif %}
            {% if perms.BIS.bulk_delete_DNAUsageRecordInfo %}
              {
                  text: '批量删除',
                  className: 'btn btn-danger fas fa-trash-alt my-1',
                  action: function ( e, dt, node, config ) {

                  },
                  attr: {
                      id: 'bulkDel'
                  }
              },
            {% endif %}
          ],
          "ajax": url0 + "?format=datatables",
          "columns": [

              {
                  data: 'id',
                  width: "1%",
                  // 若想前端显示的不一样，则需要"render"函数
                  'render': function (data, type, full, meta) {
                      return meta.row + 1 + meta.settings._iDisplayStart;
                  }
              },
              {"data": "dna_id"},
              {"data": "sample_id"},
              {"data": "sampler_id"},
              {"data": "usage_date"},
              {"data": "mass"},
              {"data": "usage"},
              {"data": "singleLB_id"},
              {"data": "memo"},
              {"data": "last_modify_time"},
              {"data": "create_time"},
              {
                  "data": null,
                  render: function (data, type, row, meta) {
                      if (row.usage === '建库成功') {
                          return ""
                      }
                  },
                  "defaultContent": '<button type="button" class="btn btn-info">更新</button>' + '&nbsp;&nbsp' +
                    '<button type="button" class="btn btn-danger">删除</button>'
              }
          ]
      });
      table.button(0).trigger();

      $('#table tbody').on('click', 'button', function () {
          let data = table.row($(this).parents('tr')).data();
          let class_name = $(this).attr('class');
          id0 = data['id'];
          console.info("click button, id:", id)
          //alert(id);
          if (class_name === 'btn btn-info') {
              // EDIT button
              MyModelInit('更新', data);
              $("#myModal").modal();
          } else {
              // DELETE button
              // alert('delete '+id);
              // $('#modal_title').text('DELETE');
              $("#confirm").modal();
          }
      });

      $('#modelForm').on('submit', function (e) {
          e.preventDefault();
          // 递交前检查，一般是检测model的外键是否存在
          let data1 = $.ajax({
              url: url1, dataType: 'json', contentType: "application/json",
              type: "get", async: false, data: {dna_id: $('#dna_id').val()}
          }).responseJSON[0];
          if (data1 === undefined) {
              $('#myModalError').text('错误！！！核酸提取编号不存在，请填写正确的核酸提取编号。');
              return
          }

          let type = $('#type').val();
          let method = '';
          let url_ajax0 = url0;
          let send_data0 = $(this).serialize();
          let old_data0;
          if (type === 'new') {
              // new
              method = 'POST';
              // POST前检查，一般是检测model的关键字段值是否存在
              data0 = $.ajax({
                  url: url0, dataType: 'json', contentType: "application/json",
                  type: "get", async: false, data: {
                      dna_id: $('#dna_id').val(), usage_date: $('#usage_date').val(),
                      usage: $('#usage').val()
                  }
              }).responseJSON[0];
              if (data0 !== undefined) {
                  $('#myModalError').text('错误！！！该条核酸使用记录已存在，无法添加。如需更新该条目，请在对应行进行更新操作。');
                  return
              }
          } else {
              // edit
              url_ajax0 = url0 + id0 + '/';
              method = 'PUT';
              old_data0 = $.ajax({
                  url: url_ajax0, dataType: 'json', contentType: "application/json",
                  type: "get", async: false
              }).responseJSON;
          }

          $.ajax({
              url: url_ajax0,
              method: method,
              data: send_data0,
              headers: {'X-HTTP-Method-Override': 'PATCH'},
              success: function () {
                  let v_tmp = $('#dna_id').val();
                  let filter1 = $('#usage').val();
                  if (type === 'new') {
                      databaseRecordAjaxPut(model0, "单项添加", "核酸提取编号：" + v_tmp);
                      $('#myModalError').text('添加成功！！！核酸提取编号：' + v_tmp);
                      // 记录样本提取表条目变化
                      if (filter1 === '建库失败') {
                          data1.failM = parseFloat(data1.failM) + parseFloat($('#mass').val());
                      } else if (filter1 === '科研项目') {
                          data1.failM = parseFloat(data1.researchM) + parseFloat($('#mass').val());
                      } else if (filter1 === '其他') {
                          data1.failM = parseFloat(data1.othersM) + parseFloat($('#mass').val());
                      }
                  } else {
                      databaseRecordAjaxPut(model0, "单项更新", "核酸提取编号：" + v_tmp);
                      $('#myModalError').text('更新成功！！！核酸提取编号：' + v_tmp);
                      // 记录样本提取表条目变化
                      if (filter1 === '建库失败') {
                          data1.failM = parseFloat(data1.failM) + parseFloat($('#mass').val()) - parseFloat(old_data0.failM);
                      } else if (filter1 === '科研项目') {
                          data1.failM = parseFloat(data1.researchM) + parseFloat($('#mass').val()) - parseFloat(old_data0.researchM);
                      } else if (filter1 === '其他') {
                          data1.failM = parseFloat(data1.othersM) + parseFloat($('#mass').val()) - parseFloat(old_data0.othersM);
                      }
                  }
                  // 更新样本提取表
                  $.ajax({
                      url: url1 + data1.id + '/',
                      method: 'PUT',
                      data: $.param(data1),
                      headers: {'X-HTTP-Method-Override': 'PATCH'},
                      success: function () {
                          databaseRecordAjaxPut("ExtractInfo", "单项更新", "核酸提取编号：" + v_tmp);
                      },
                      error: function (jqXHR, textStatus, errorThrown) {
                          console.log(jqXHR + ';' + textStatus + ';' + errorThrown)
                      }
                  });

                  setTimeout(
                      function () {
                          window.location.reload(true);
                      }, 3000
                  );
              },
              error: function (jqXHR, textStatus, errorThrown) {
                  $('#myModalError').text('出现错误！！！请联系管理员');
                  console.info(url_ajax0, method, send_data0);
                  console.log(jqXHR + ';' + textStatus + ';' + errorThrown)
              }
          });
      });

      function delete_by_id (id_func){
          let url_ajax0 = url0 + id_func + '/';
          let old_data0 = $.ajax({
              url: url_ajax0, dataType: 'json', contentType: "application/json",
              type: "get", async: false
          }).responseJSON;
          let res = [];
          $.ajax({
              url: url_ajax0,
              method: 'DELETE',
              success: function () {
                  res.push("success");
                  res.push(id_func);
                  // 更新样本提取表
                  let data1 = $.ajax({
                      url: url1, dataType: 'json', contentType: "application/json",
                      type: "get", async: false, data: {dna_id: old_data0.dna_id}
                  }).responseJSON[0];
                  if (old_data0.usage === '建库失败') {
                      data1.failM = parseFloat(data1.failM) - parseFloat(old_data0.mass);
                  } else if (old_data0.usage === '科研项目') {
                      data1.researchM = parseFloat(data1.researchM) - parseFloat(old_data0.mass);
                  } else if (old_data0.usage === '其他') {
                      data1.othersM = parseFloat(data1.othersM) - parseFloat(old_data0.mass);
                  }
                  $.ajax({
                      url: url1 + data1.id + '/',
                      method: 'PUT',
                      data: $.param(data1),
                      headers: {'X-HTTP-Method-Override': 'PATCH'},
                      success: function () {
                          res.push("success");
                          res.push(data1.id);
                      },
                      error: function (jqXHR, textStatus, errorThrown) {
                          res.push("error");
                          res.push(jqXHR + ';' + textStatus + ';' + errorThrown)
                      }
                  });
              },
              error: function (jqXHR, textStatus, errorThrown) {
                  res.push("error");
                  res.push(jqXHR + ';' + textStatus + ';' + errorThrown);
                  res.push("error");
                  res.push(jqXHR + ';' + textStatus + ';' + errorThrown);
              }
          });
          return res;
      }

      $('#confirm').on('click', '#delete', function (e) {
          let res = delete_by_id(id0);
          if (res[2] === "success") {
              databaseRecordAjaxPut("ExtractInfo", "单项更新", "id：" + res[3]);
          } else {
              console.log(res[3]);
          }
          if (res[0] === "success") {
              databaseRecordAjaxPut(model0, "单项删除", "id：" + res[1]);
              window.location.reload(true);
          } else {
              console.log(res[1]);
          }
      });

      $('#new').on('click', function (e) {
          MyModelInit('新增', {});
          $("#myModal").modal();
      });

      $('#upload').on('click', function (e) {
          $('#uploadOperator').val("");
          $('#uploadFile').val("");
          $('#uploadError').val("");
          $('#uploadUrl').val(model0);
          $("#uploadModal").modal();
      });

      $('#bulkDel').on('click', function (e) {
          $('#bulkDelUrl').val(model0);
          $("#bulkDelModal").modal();
      });

      $('#bulkDelModal').on('click', '#bulkDelete', function (e) {
            let arrayLen = table.rows(".selected").data().length;
            if (arrayLen > 0) {
                let id_list0 = [];
                let id_list1 = [];
                for (let i = 0; i < arrayLen; i++) {
                    let delete_id = table.rows(".selected").data()[i]['id'];
                    let res = delete_by_id(delete_id);
                    if (res[0] === "success") {
                        id_list0.push(res[1]);
                    }
                    if (res[2] === "success") {
                        id_list1.push(res[3]);
                    }
                }
                databaseRecordAjaxPut(model0, "批量删除", "id_list：[" + id_list0 + "]");
                databaseRecordAjaxPut("ExtractInfo", "批量更新", "id_list：[" + id_list1 + "]");
                window.location.reload(true);
            } else {
                $('#bulkDelError').text('没有行被选中，请先选中目标行。');
            }
      });

      $('.downloadExcel').on('click', function (e) {
          e.preventDefault();
          window.location.href = '/ADVANCE/download_excel/BIS_' + model0 + '/'
      });

      $('#myModalReset').on('click', function (e) {
          e.preventDefault();
          if ($('#modal_title').text() === '更新') {
              MyModelInit('更新', dataModelForm);
          } else {
              MyModelInit('新增', {});
          }
      });

      $("#modelForm input[type='text']").focus(function () {
          let key2 = $(this).attr('id');
          let values = $.ajax({
              url: "{% url 'ADVANCE:unique' %}", data: {model: model0, filed: key2},
              dataType: 'json', contentType: "application/json",
              method: "GET", async: false
          }).responseJSON.values;
          console.info("values:", values, "; key2:", key2);
          input_autocomplete(values, '#' + key2);
      });

      $('#new').on('click', function (e) {
          MyModelInit('新增', {});
          $('#ModalFormHeader').text('只能添加 非“建库成功” 的记录，如需添加 “建库成功” 记录，请转到不同实验项目中的样本建库信息页面');
          $("#myModal").modal();
      });

    });
</script>
{% endblock %}
